:root {
  --ls-draggable-handle-height: 30px;
}

.cp__plugins {
  &-page {
    margin: -2rem;
    padding: 1.5rem 2rem;
    outline: none;

    @screen xl {
      width: 1260px;
    }

    > h1 {
      margin: 0;
      padding: 0;
      font-size: 22px;
      font-weight: 600;
    }

    .admonitionblock {
      margin: 1rem 15px;

      .text-lg {
        font-size: 16px;
      }
    }

    .tabs {
      .ui__button {
        margin: 0 8px;

        > span {
          display: flex;
          align-items: center;
          font-size: 16px;
          font-weight: normal;

          svg {
            margin-right: 6px;
          }
        }

        &.active {
        }
      }
    }

    .panels {
      margin: 0 -32px -24px;
    }

    .secondary-tabs {
      button {
        margin-right: 5px;
        background: transparent;

        .ti, .tie {
          margin-right: 3px;
        }

        &.active {
          @apply !text-primary;
        }

        &:hover {
          @apply text-accent-10;
        }
      }
    }

    .control-tabs {
      @apply px-6 transition-shadow;

      &.scrolled {
        box-shadow: 0 4px 6px -6px #ccc;
      }

      .ui__dropdown-trigger {
        .ti-circle {
          visibility: hidden;
        }
      }

      .dropdown-wrapper {
        min-width: 14rem;
      }

      .title-wrap {
        @apply whitespace-nowrap;
      }
    }

    .ui__button {
      position: relative;
      border: none;

      &:active {
        opacity: .8;
      }

      &.contribute {
        position: absolute;
        top: -46px;
        right: 20px;
        background: transparent;
        font-size: 12px;
        opacity: .8;
        display: none;

        @screen md {
          display: block;
        }
      }

      &.load-unpacked {
        opacity: .9;
        background: transparent;
      }

      &.sort-or-filter-by, &.more-do {
        padding: 0 6px;
      }

      &.picked {
        &:after {
          content: " ";
          position: absolute;
          top: -2px;
          right: 4px;
          background-color: red;
          width: 4px;
          height: 4px;
          border-radius: 50%;
        }
      }
    }

    .search-ctls {
      margin: 3px 13px;
      display: flex;
      align-items: center;
      position: relative;

      small.s1 {
        left: 8px;
        top: 6px;
      }

      small.s2 {
        right: 4px;
        top: 6px;
        user-select: none;
        cursor: pointer;
        z-index: 1;
      }

      .form-input {
        background-color: var(--ls-primary-background-color);
        padding: 6px 7px 5px 29px;
        opacity: .5;

        &:focus {
          background-color: var(--ls-secondary-background-color);
          opacity: 1;
        }
      }
    }
  }

  &-installed {
    padding-top: 5px;
  }

  &-marketplace {
    padding-top: 5px;

    &.has-installing {
      .ctl {
        a.btn {
          pointer-events: none;
        }
      }
    }
  }

  &-item-lists {
    @apply w-full max-h-[56vh] overflow-y-auto;

    &-inner {
      @apply grid grid-flow-row gap-3 px-6
      grid-cols-1 md:grid-cols-2 lg:grid-cols-3;
    }
  }

  &-item-card {
    @apply flex py-3 px-1 rounded-md;

    background-color: var(--ls-tertiary-background-color, hsl(var(--muted)));
    height: 150px;

    li {
      margin: 0;
    }

    .head {
      max-height: 50px;
      overflow: hidden;
      line-height: 24px;
      padding-right: 24px;
    }

    .desc {
      height: 60px;
      overflow: hidden;

      > p {
        @apply overflow-hidden overflow-ellipsis;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
      }
    }

    .flag {
      position: absolute;
      bottom: 16px;
      left: 0;
      width: 100%;

      > p {
        color: var(--ls-primary-text-color);
        opacity: .8;

        > small {
          cursor: pointer;
        }
      }

      &.is-top {
        width: unset;
        top: 4px;
        right: 6px;
        left: unset;
        bottom: unset;

        &:hover {
          opacity: .8;
        }
      }

      a {
        color: var(--ls-primary-text-color);
        opacity: .7;
      }
    }

    > .l {
      padding: 8px;

      svg, .icon {
        width: 60px;
        height: 60px;
        opacity: .8;

        &:hover {
          opacity: 1;
        }
      }
    }

    > .r {
      flex: 1;
      position: relative;

      p {
        @apply py-1 m-0;
      }

      .ctl {
        @apply flex pl-2 items-center justify-between absolute w-full;

        bottom: -8px;
        right: 7px;

        .de {
          font-size: 10px;
          padding: 5px 2px;
          padding-right: 3px;
          border-radius: 2px;
          margin-right: 5px;
          user-select: none;
          transition: none;
          opacity: .2;
          position: relative;
          z-index: var(--ls-z-index-level-1);

          .ti, .tie {
            font-size: 16px;
          }

          .menu-list {
            @apply shadow-md rounded-sm absolute hidden list-none overflow-hidden m-0 p-0;

            background-color: var(--ls-primary-background-color);
            top: 22px;
            left: 0;
            min-width: 120px;

            > li {
              margin: 0;
              padding: 5px;
              transition: background-color .2s;
              user-select: none;
              font-weight: bold;
              opacity: .9;

              &:hover {
                background-color: var(--ls-quaternary-background-color);

                &:active {
                  opacity: 1;
                }
              }
            }
          }

          &.err {
            @apply text-red-500 opacity-100;
          }

          &.log {
            padding: 5px;
          }

          &.sponsors {
            .menu-list {
              min-width: auto;
              white-space: nowrap;

              > li {
                &:hover {
                  background-color: unset;
                }
              }

              .ti, .tie {
                font-size: 12px;
              }
            }
          }

          svg {
            width: 15px;
            height: 15px;
          }

          &:hover {
            opacity: .9;

            .menu-list {
              display: block;
            }
          }
        }

        > .l {
          @apply flex items-center;
          margin-left: -70px;
        }

        a.btn {
          display: inline-flex;
          align-items: center;
          line-height: 1;
          padding: 4px;
          font-size: 13px;
          border-radius: 2px;
          user-select: none;
          position: relative;
          margin-left: 4px;

          svg {
            opacity: .3;
          }

          &:hover {
            svg {
              opacity: .8;
            }
          }

          &:active {
            opacity: .6;
          }

          &.disabled {
            pointer-events: none;
            cursor: default;
            color: var(--ls-primary-text-color);
            opacity: .3;
          }

          &.installing {
            small {
              position: absolute;
              transform: scale(.5) translateX(-180%);
              margin-right: 2px;
            }
          }
        }

        .ui__toggle {
          margin-left: 5px;
        }
      }
    }

    &.market {
      &.installed {

      }

      .ctl {
        padding-left: 12px;
        bottom: -5px;
      }
    }

    .updates-actions {
      opacity: 0;
    }

    &:hover {
      .updates-actions {
        opacity: 1;
      }
    }

    &.has-new-version, &.updating {
      .updates-actions {
        opacity: 1;
      }
    }

    &.market.installed {
      opacity: .5;

      &:hover {
        opacity: 1;
      }
    }
  }

  &-details {
  }

  &-waiting-updates {
    margin: -15px;

    > ul {
      li {
        user-select: none;
        justify-content: space-between;
        opacity: .9;

        sup {
          padding-left: 8px;
          font-weight: 400;
        }

        &:hover, &.checked {
          opacity: 1;
        }
      }
    }
  }

  &-settings {
    > header {
      padding: 8px 12px;
      border-bottom: 1px solid var(--ls-quaternary-background-color);

      h1 {
        @apply flex items-center text-[22px] m-0 space-x-1;
      }
    }

    &-inner {
      position: relative;
      padding: 10px 0 20px;

      > .edit-file {
        position: absolute;
        top: 12px;
        right: 8px;
      }

      .heading-item {
        margin: 12px 12px 6px;
        border-bottom: 1px solid var(--ls-border-color, #738694);

        h2 {
          font-weight: bold;
        }

        small:empty {
          display: none;
        }
      }

      .desc-item {
        padding: 12px 12px 6px;

        > h2 {
          padding-bottom: 2px;
          font-weight: 600;
          font-size: 13px;
          line-height: 1;
          display: flex;
          align-items: center;

          code {
            margin-right: 4px;
            line-height: 1.2;
          }
        }

        > .form-control {
          display: flex;
          align-items: center;
          padding: 5px 2px;

          > small {
            user-select: none;
          }
        }

        &.as-toggle {
        }

        &.as-input, &.as-enum, &.as-object {
          > .form-control {
            padding-top: 4px;
            flex-direction: column;
            align-items: flex-start;

            small {
              padding-bottom: 6px;
              width: 100%;
            }
          }
        }

        &.as-enum {
          > .form-control {
            > .wrap {
              flex-direction: column;
              width: 100%;
              margin-top: -3px;
            }
          }
        }

        &:hover {
          background: var(--ls-tertiary-background-color);
        }

        .ui__radio-list, .ui__checkbox-list {
          display: flex;
          align-items: center;
          padding-top: 3px;
          flex-wrap: wrap;

          label {
            padding-right: 15px;
            user-select: none;
            white-space: nowrap;
            margin-top: 2px;
          }

          input {
            margin-right: 6px;
          }
        }

        .form-input {
          padding: 5px;
          width: 70%;
        }

        textarea.form-input {
          overflow-y: auto;
          resize: vertical;
        }

        .form-select {
          width: 50%;
          padding: 4px 4px 4px 7px !important;
          margin: 5px 0 0;
        }
      }
    }

    .cp__settings-inner {
      aside {
        @apply max-h-[70vh] overflow-auto p-3;

        ul {
          @apply list-none p-0 m-0;

          img.icon {
            @apply w-[20px] h-[20px];
          }

          li {
            @apply p-1.5 rounded;

            a {
              @apply mb-0 text-gray-11;
            }

            strong {
              @apply overflow-hidden text-ellipsis whitespace-nowrap;
            }
          }
        }
      }
    }

    article .panel-wrap {
      padding: 0;
      min-width: 600px;
      width: 100%;
      max-width: 760px;
    }

    .html-content {
      > p {
        padding-bottom: 2px;
        margin: 0;
      }
    }
  }
}

.cp__themes {
  &-installed {
    margin: -2rem;
    outline: none;
    padding: .5rem;

    .it {
      user-select: none;
      border: 1px solid transparent;
      margin-bottom: 4px;
      cursor: pointer;
      opacity: .8;

      .name {
        font-weight: 600;
      }

      &:hover, &.is-active {
        @apply opacity-100 bg-gray-06;
      }

      &.is-selected {
        @apply opacity-100;
      }
    }
  }
}

.lsp-iframe-sandbox, .lsp-shadow-sandbox, .lsp-ui-float {
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0;
  padding: 0;

  &-container {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    visibility: hidden;
    display: none;
    height: 0;
    width: 0;
    padding: 0;
    margin: 0;

    &.visible {
      z-index: var(--ls-z-index-level-2);
      width: 100%;
      height: 100%;
      visibility: visible;
      display: block;
    }

    &[draggable=true] {
      -webkit-user-drag: none;

      > .draggable-handle {
        display: block;
        height: var(--ls-draggable-handle-height);
        cursor: move;
        user-select: none;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        overflow: hidden;

        > .th {
          display: flex;
          align-items: center;
          height: var(--ls-draggable-handle-height);
          user-select: none;
          position: relative;
          background-color: var(--ls-secondary-background-color);
          color: var(--ls-primary-text-color);

          > .l {
            flex-basis: 80%;
          }

          > .r {
            position: absolute;
            right: 0;
            top: 0;
          }

          h3 {
            padding: 0 5px;
            white-space: nowrap;
            max-width: 60%;
            overflow: hidden;
            -webkit-line-clamp: 1;
            text-overflow: ellipsis;
          }

          a.button {
            &:hover {
              background-color: transparent;
            }
          }
        }
      }

      .lsp-iframe-sandbox,
      .lsp-shadow-sandbox,
      .ls-ui-float-content {
        height: calc(100% - var(--ls-draggable-handle-height));
        width: 100%;
        margin-top: var(--ls-draggable-handle-height);
        overflow: auto;
      }

      .ls-ui-float-content {
        user-select: text;
      }

      &.is-dragging {
        /*height: var(--ls-draggable-handle-height) !important;*/
        opacity: .7;

        > .draggable-handle {
          background-color: rgba(0, 0, 0, .1);
          height: 100%;
          z-index: 3;
        }
      }
    }

    &[resizable=true] {
      > .resizable-handle {
        position: absolute;
        bottom: -1px;
        right: -1px;
        height: 15px;
        width: 15px;
        z-index: 2;
        opacity: 0;
        cursor: nwse-resize;
        user-select: none;
      }

      &.is-resizing {
        > .resizable-handle {
          width: 90%;
          height: 80%;
        }
      }
    }
  }
}

.lsp-ui-float-container {
  top: 40%;
  left: 30%;
  border: 2px solid var(--ls-border-color);
  border-radius: 6px;
  overflow: hidden;

  .draggable-handle {
  }

  &.visible {
    height: unset;
  }
}

.ui-items-container {
  &[data-type=toolbar] {
    @apply flex items-center;

    > .list-wrap {
      @apply flex items-center flex-nowrap overflow-x-hidden transition-[max-width];
    }

    > .injected-ui-item-toolbar {
      @apply hover:opacity-100 transition-opacity;
    }
  }

  &[data-type=pagebar] {
    @apply flex items-start pl-2;

    > .injected-ui-item-pagebar {
      @apply pr-3 opacity-30 hover:opacity-100 transition-opacity;
    }

    > .list-wrap {
      @apply flex items-center flex-nowrap overflow-x-hidden pt-[14px];
    }

    a.button {
      @apply flex items-center;

      color: var(--ls-primary-text-color);
    }
  }

  .toolbar-plugins-manager {
    &-trigger {
      .menu-links-wrapper {
        max-height: 80vh;
      }

      .menu-link {
        @apply px-[5px] py-1.5;

        &.extra-item {
          @apply opacity-80 px-4 py-1.5;

          .title-wrap {
            margin-left: 8px !important;
          }

          &:hover {
            opacity: 1;
          }
        }
      }

      .item-wrap {
        padding-right: 28px;
        font-size: 14px;
        position: relative;

        div[data-injected-ui] :is(.ti, .tie) {
          position: relative;
          bottom: -1px;
        }
      }

      .pin {
        position: absolute;
        top: 0;
        right: 0;
        height: 100%;
        padding: 0 6px;

        &.pinned {
          color: var(--ls-link-ref-text-color);
          opacity: 90;
        }
      }

      .menu-links-wrapper {
        a {
          @apply !text-popover-foreground/80;

          &.button {
            @apply h-auto hover:bg-transparent scale-95;
          }
        }
      }
    }
  }
}

.ui-fenced-code {
  &-wrap {
    &:not(.is-active) {
      .ui-fenced-code-editor {
        display: none !important;
      }
    }

    &.is-active {
      .ui-fenced-code-result {
        @apply pt-2;
      }
    }
  }

  &-result {
    @apply relative;

    > .actions {
      @apply absolute top-2 right-1 z-10 opacity-0 transition-opacity;

      .ui__button {
        font-size: 13px;
        padding: 4px;
        margin-left: 6px;
      }
    }

    &:hover {
      > .actions {
        @apply opacity-100;
      }
    }
  }
}

.lsp-frame-readme {
  margin: -2rem;
  min-height: 75vh;
  min-width: 900px;
}

html[data-theme='dark'] {
  .lsp-frame-readme {
    background-color: #eeeeee;
  }

  .cp__plugins-page {
    .control-tabs {
      &.scrolled {
        box-shadow: 0 4px 6px -6px #666;
      }
    }
  }
}

.block-content {
  .lsp-hook-ui-slot {
    display: inline-flex;

    [data-injected-ui] {
      display: inline-flex;
    }
  }

  .block-slotted-body {
    .lsp-hook-ui-slot {
      display: block;

      [data-injected-ui] {
        display: flex;
        flex-direction: column;
      }
    }
  }
}

.ui__modal[label=plugin-settings-modal] {
  .ui__modal-close-wrap {
    padding-top: 14px;
  }
}

.ui__modal[label=plugins-dashboard] {
  .panel-content {
    overflow-y: auto;
    max-height: calc(100vh - 50px);
  }
}

body[data-page=plugins] {
  .cp__sidebar-main-content {
    max-width: 1280px !important;
    width: 80%;
    padding-left: 30px;
    padding-right: 30px;
  }
}
